| MAKE A COPY               | Instruction Metadata |           |        |           | ROM Input [1] |         | Control Signals                |                 |                |                |                |                 |                |                 |                |                |      |
|---------------------------|----------------------|-----------|--------|-----------|---------------|---------|--------------------------------|-----------------|----------------|----------------|----------------|-----------------|----------------|-----------------|----------------|----------------|------|
| OF THIS SHEET Instruction |                      |           |        |           |               |         | addi is provided as an example |                 |                |                |                |                 |                |                 |                |                |      |
|                           | Type                 | Opcode    | Funct3 | Funct7    | Binary        | Decimal | RegWEn                         | ImmSel          | BrUn           | ASel           | BSel           | ALUSel          | MemRW          | WBSel           | CSRSel         | CSRWen         | Hex  |
|                           |                      |           |        |           |               |         | 1 binary digit                 | 3 binary digits | 1 binary digit | 1 binary digit | 1 binary digit | 4 binary digits | 1 binary digit | 2 binary digits | 1 binary digit | 1 binary digit |      |
| add rd, rs1, rs2          |                      | 0ь0110011 | 0b000  | 0b0000000 | 00000000      | 0       | 1                              | 000             | 0              | 0              | 0              | 0000            | 0              | 01              | 0              | 0              | 8004 |
| mul rd, rs1, rs2          |                      |           | 0b000  | 0b0000001 | 0b000001      | 1       | 1                              | 000             | 0              | 0              | 0              | 1000            | 0              | 01              | 0              | 0              | 8104 |
| sub rd, rs1, rs2          | R                    |           | 0b000  | 0b0100000 | 0b000010      | 2       | 1                              | 000             | 0              | 0              | 0              | 1100            | 0              | 01              | 0              | 0              | 8184 |
| sll rd, rs1, rs2          |                      |           | 0b001  | 0b0000000 | 0b000011      | 3       | 1                              | 000             | 0              | 0              | 0              | 0001            | 0              | 01              | 0              | 0              | 8024 |
| mulh rd, rs1, rs2         |                      |           | 0b001  | 0b0000001 | 0b000100      | 4       | 1                              | 000             | 0              | 0              | 0              | 1001            | 0              | 01              | 0              | 0              | 8124 |
| mulhu rd, rs1, rs2        |                      |           | 0b011  | 0b0000001 | 0b000101      | 5       | 1                              | 000             | 0              | 0              | 0              | 1011            | 0              | 01              | 0              | 0              | 8164 |
| slt rd, rs1, rs2          |                      |           | 0b010  | 0b0000000 | 0b000110      | 6       | 1                              | 000             | 0              | 0              | 0              | 0010            | 0              | 01              | 0              | 0              | 8044 |
| xor rd, rs1, rs2          |                      |           | 0b100  | 0b0000000 | 0b000111      | 7       | 1                              | 000             | 0              | 0              | 0              | 0100            | 0              | 01              | 0              | 0              | 8084 |
| srl rd, rs1, rs2          |                      |           | 0b101  | 0b0000000 | 0b001000      | 8       | 1                              | 000             | 0              | 0              | 0              | 0101            | 0              | 01              | 0              | 0              | 80A4 |
| sra rd, rs1, rs2          |                      |           | 0b101  | 0b0100000 | 0b001001      | 9       | 1                              | 000             | 0              | 0              | 0              | 1101            | 0              | 01              | 0              | 0              | 81A4 |
| or rd, rs1, rs2           |                      |           | 0b110  | 0b0000000 | 0b001010      | 10      | 1                              | 000             | 0              | 0              | 0              | 0110            | 0              | 01              | 0              | 0              | 80C4 |
| and rd, rs1, rs2          |                      |           | 0b111  | 0b0000000 | 0b001011      | 11      | 1                              | 000             | 0              | 0              | 0              | 0111            | 0              | 01              | 0              | 0              | 80E4 |
| lb rd, offset(rs1)        |                      | 0b0000011 | 0b000  |           | 0b001100      | 12      | 1                              | 001             | 0              | 0              | 1              | 0000            | 0              | 00              | 0              | 0              | 9200 |
| Ih rd, offset(rs1)        |                      |           | 0b001  |           | 0b001101      | 13      | 1                              | 001             | 0              | 0              | 1              | 0000            | 0              | 00              | 0              | 0              | 9200 |
| lw rd, offset(rs1)        |                      |           | 0b010  |           | 0b001110      | 14      | 1                              | 001             | 0              | 0              | 1              | 0000            | 0              | 00              | 0              | 0              | 9200 |
| addi rd, rs1, imm         |                      | 0ь0010011 | 0b000  |           | 0b001111      | 15      | 1                              | 001 [3]         | 0 [4]          | 0 [5]          | 1 [6]          | 0000            | 0              | 01 [7]          | 0              | 0              | 9204 |
| slli rd, rs1, imm         | I                    |           | 0b001  | 0b0000000 | 0b010000      | 16      | 1                              | 001             | 0              | 0              | 1              | 0001            | 0              | 01              | 0              | 0              | 9224 |
| slti rd, rs1, imm         |                      |           | 0b010  |           | 0b010001      | 17      | 1                              | 001             | 0              | 0              | 1              | 0010            | 0              | 01              | 0              | 0              | 9244 |
| xori rd, rs1, imm         |                      |           | 0b100  |           | 0b010010      | 18      | 1                              | 001             | 0              | 0              | 1              | 0100            | 0              | 01              | 0              | 0              | 9284 |
| srli rd, rs1, imm         |                      |           | 0b101  | 0b0000000 | 0b010011      | 19      | 1                              | 001             | 0              | 0              | 1              | 0101            | 0              | 01              | 0              | 0              | 92A4 |
| srai rd, rs1, imm         |                      |           | 0b101  | 0b0100000 | 0b010100      | 20      | 1                              | 001             | 0              | 0              | 1              | 1101            | 0              | 01              | 0              | 0              | 93A4 |
| ori rd, rs1, imm          |                      |           | 0b110  |           | 0b010101      | 21      | 1                              | 001             | 0              | 0              | 1              | 0110            | 0              | 01              | 0              | 0              | 92C4 |
| andi rd, rs1, imm         |                      |           | 0b111  |           | 0b010110      | 22      | 1                              | 001             | 0              | 0              | 1              | 0111            | 0              | 01              | 0              | 0              | 92E4 |
| sb rs2, offset(rs1)       |                      | 0b0100011 | 00000  |           | 0b010111      | 23      | 0                              | 010             | 0              | 0              | 1              | 0000            | 1              | 11              | 0              | 0              | 221C |
| sh rs2, offset(rs1)       | S                    |           | 0b001  |           | 0b011000      | 24      | 0                              | 010             | 0              | 0              | 1              | 0000            | 1              | 11              | 0              | 0              | 221C |
| sw rs2, offset(rs1)       |                      |           | 0b010  |           | 0b011001      | 25      | 0                              | 010             | 0              | 0              | 1              | 0000            | 1              | 11              | 0              | 0              | 221C |
| beq rs1, rs2, offset      |                      |           | 0b000  |           | 0b011010      | 26      | 0                              | 011             | 0              | 1              | 1              | 0000            | 0              | 11              | 0              | 0              | 360C |
| bne rs1, rs2, offset      |                      |           | 0b001  |           | 0b011011      | 27      | 0                              | 011             | 0              | 1              | 1              | 0000            | 0              | 11              | 0              | 0              | 360C |
| blt rs1, rs2, offset      | SB                   | 0b1100011 | 0b100  |           | 0b011100      | 28      | 0                              | 011             | 0              | 1              | 1              | 0000            | 0              | 11              | 0              | 0              | 360C |
| bge rs1, rs2, offset      | 98                   | 001100011 | 0b101  |           | 0b011101      | 29      | 0                              | 011             | 0              | 1              | 1              | 0000            | 0              | 11              | 0              | 0              | 360C |
| bltu rs1, rs2, offset     |                      |           | 0b110  |           | 0b011110      | 30      | 0                              | 011             | 1              | 1              | 1              | 0000            | 0              | 11              | 0              | 0              | 3E0C |
| bgeu rs1, rs2, offset     |                      |           | 0b111  |           | 0b011111      | 31      | 0                              | 011             | 1              | 1              | 1              | 0000            | 0              | 11              | 0              | 0              | 3E0C |
| auipc rd, offset          | U                    | 0b0010111 |        |           | 0b100000      | 32      | 1                              | 100             | 0              | 1              | 1              | 0000            | 0              | 01              | 0              | 0              | C604 |
| lui rd, offset            | U                    | 0b0110111 |        |           | 0b100001      | 33      | 1                              | 100             | 0              | 0              | 1              | 1111            | 0              | 01              | 0              | 0              | C3E4 |
| jal rd, imm               | UJ                   | 0b1101111 |        |           | 0b100010      | 34      | 1                              | 101             | 0              | 1              | 1              | 0000            | 0              | 10              | 0              | 0              | D608 |
| jalr rd, rs1, imm         | - 1                  | 0b1100111 | 0b000  |           | 0b100011      | 35      | 1                              | 001             | 0              | 0              | 1              | 0000            | 0              | 10              | 0              | 0              | 9208 |
| csrw rd, csr, rs1         | CSR                  | 0b1110011 | 0b001  |           | 0b100100      | 36      | 0                              | 000             | 0              | 0              | 0              | 0000            | 0              | 11              | 0              | 1              | 000D |
| csrwi rd, csr, uimm       | CoR                  |           | 0b101  |           | 0b100101      | 37      | 0                              | 110             | 0              | 0              | 0              | 0000            | 0              | 11              | 1              | 1              | 600F |

- [1] This is the value that will be passed into the ROM
- [2] This is the value that will be outputted from the ROM. It's all the control signals concatenated together.
- [3] This value is provided as an example. Based on your design for the immediate generator, you may need to modify this value to generate the correct immediate value
- [4] This value actually doesn't matter because the addi instruction never uses the branch comparator. However, you must fill out every cell so the control bits line up properly
- [5] This value is provided as an example. Based on your design for the A MUX, you may need to modify this value to generate the correct immediate value
- [6] This value is provided as an example. Based on your design for the B MUX, you may need to modify this value to generate the correct immediate value
- [7] This value is provided as an example. Based on your design for the Writeback MUX, you may need to modify this value to generate the correct immediate value